import { useDict } from '@/utils/dict'
import { download } from '@/utils/request'

import { addDateRange, handleTree, parseTime, resetForm, selectDictLabel, selectDictLabels } from '@/utils/ruoyi'
import { createApp } from 'vue'
// 字典标签组件
import DictTag from '@/components/DictTag'
// 富文本组件
import Editor from '@/components/Editor'
// 文件上传组件
import FileUpload from '@/components/FileUpload'
// 图片预览组件
import ImagePreview from '@/components/ImagePreview'
// 图片上传组件
import ImageUpload from '@/components/ImageUpload'

// 分页组件
import Pagination from '@/components/Pagination'
// 自定义表格工具组件
import RightToolbar from '@/components/RightToolbar'

import SvgIcon from '@/components/SvgIcon'

import elementIcons from '@/components/SvgIcon/svgicon'

import App from './App'

import directive from './directive' // directive

// 注册指令
import plugins from './plugins' // plugins
import router from './router'

import store from './store'
// unocss
import 'virtual:uno.css'
import '@unocss/reset/tailwind-compat.css'
// element-plus
import 'element-plus/theme-chalk/dark/css-vars.css'
// 全局样式
import '@/assets/styles/index.scss' // global css
// svg图标
import 'virtual:svg-icons-register'
import './permission' // permission control

import 'element-plus/theme-chalk/el-message.css'
import 'element-plus/theme-chalk/el-dialog.css'
import 'element-plus/theme-chalk/el-message-box.css'

import { LazyVxeTable, LazyVxeUI } from '@/plugins/vxetable.js';

const app = createApp(App)

// 全局方法挂载
app.config.globalProperties.useDict = useDict
app.config.globalProperties.download = download
app.config.globalProperties.parseTime = parseTime
app.config.globalProperties.resetForm = resetForm
app.config.globalProperties.handleTree = handleTree
app.config.globalProperties.addDateRange = addDateRange
app.config.globalProperties.selectDictLabel = selectDictLabel
app.config.globalProperties.selectDictLabels = selectDictLabels

// 全局组件挂载
app.component('DictTag', DictTag)
app.component('Pagination', Pagination)
app.component('FileUpload', FileUpload)
app.component('ImageUpload', ImageUpload)
app.component('ImagePreview', ImagePreview)
app.component('RightToolbar', RightToolbar)
app.component('Editor', Editor)

app.use(router)
app.use(store)
app.use(plugins)
app.use(LazyVxeTable)
app.use(LazyVxeUI)
app.use(elementIcons)
app.component('svg-icon', SvgIcon)

directive(app)
app.mount('#app')
